*&---------------------------------------------------------------------*
*& Report  ZDEMO_COLORING_ROWS_FM_ALV
*&
*&---------------------------------------------------------------------*
 REPORT  ZDEMO_EXCPS_IN_FM_ALV.
TYPE-POOLS SLIS.

 TYPES : BEGIN OF ty_ekko,
          ebeln TYPE ekko-ebeln,  "PO No
          lifnr TYPE ekko-lifnr,  "Vendor No
          AEDAT TYPE AEDAT,       "Date Of Creation
          EXCP  TYPE I,
        END OF ty_ekko.
DATA : WA_EKKO       TYPE TY_EKKO,
       IT_EKKO       TYPE TABLE OF TY_EKKO,
       IT_FIELDCAT   TYPE SLIS_T_FIELDCAT_ALV,
       WA_FIELDCAT   TYPE LINE OF SLIS_T_FIELDCAT_ALV,
       IS_LAYOUT     TYPE SLIS_LAYOUT_ALV.

*Fill the FieldCata Log
*lifnr
  CLEAR WA_FIELDCAT.
        WA_FIELDCAT-FIELDNAME = 'LIFNR'.
        WA_FIELDCAT-COL_POS   = 2.
        WA_FIELDCAT-SELTEXT_M = 'Vendor Number'.
        WA_FIELDCAT-JUST      = 'C'.
 APPEND WA_FIELDCAT TO IT_FIELDCAT.

  CLEAR WA_FIELDCAT.
        WA_FIELDCAT-FIELDNAME = 'EBELN'.
        WA_FIELDCAT-COL_POS   = 1.
        WA_FIELDCAT-SELTEXT_M = 'Purchase Order No'.
        WA_FIELDCAT-key       = 'X'.
 APPEND WA_FIELDCAT TO IT_FIELDCAT.

   CLEAR WA_FIELDCAT.
        WA_FIELDCAT-FIELDNAME = 'AEDAT'.
        WA_FIELDCAT-COL_POS   = 3.
        WA_FIELDCAT-SELTEXT_M = 'Creation Date'.
*        WA_FIELDCAT-EMPHASIZE = 'C51'.
 APPEND WA_FIELDCAT TO IT_FIELDCAT.

SELECT EBELN LIFNR AEDAT INTO TABLE IT_EKKO FROM EKKO
                                         UP TO 15 ROWS.
WA_EKKO-EXCP = 3. "Green
MODIFY IT_EKKO FROM WA_EKKO TRANSPORTING excp
                      WHERE EBELN = '3000000010'.
WA_EKKO-EXCP = 2. "Yellow
MODIFY IT_EKKO FROM WA_EKKO TRANSPORTING excp
                      WHERE EBELN < '3000000010'.

WA_EKKO-EXCP = 1. "Red
MODIFY IT_EKKO FROM WA_EKKO TRANSPORTING excp
                      WHERE EBELN > '3000000010'.

IS_LAYOUT-LIGHTS_FIELDNAME  = 'EXCP'.

CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
 EXPORTING
*   I_INTERFACE_CHECK                 = ' '
*   I_BYPASSING_BUFFER                = ' '
*   I_BUFFER_ACTIVE                   = ' '
*   I_CALLBACK_PROGRAM                = ' '
*   I_CALLBACK_PF_STATUS_SET          = ' '
*   I_CALLBACK_USER_COMMAND           = ' '
*   I_CALLBACK_TOP_OF_PAGE            = ' '
*   I_CALLBACK_HTML_TOP_OF_PAGE       = ' '
*   I_CALLBACK_HTML_END_OF_LIST       = ' '
*   I_STRUCTURE_NAME                  =
*   I_BACKGROUND_ID                   = ' '
*   I_GRID_TITLE                      =
*   I_GRID_SETTINGS                   =
   IS_LAYOUT                         = IS_LAYOUT
   IT_FIELDCAT                       = IT_FIELDCAT
*   IT_EXCLUDING                      =
*   IT_SPECIAL_GROUPS                 =
*   IT_SORT                           =
*   IT_FILTER                         =
*   IS_SEL_HIDE                       =
*   I_DEFAULT                         = 'X'
*   I_SAVE                            = ' '
*   IS_VARIANT                        =
*   IT_EVENTS                         =
*   IT_EVENT_EXIT                     =
*   IS_PRINT                          =
*   IS_REPREP_ID                      =
*   I_SCREEN_START_COLUMN             = 0
*   I_SCREEN_START_LINE               = 0
*   I_SCREEN_END_COLUMN               = 0
*   I_SCREEN_END_LINE                 = 0
*   I_HTML_HEIGHT_TOP                 = 0
*   I_HTML_HEIGHT_END                 = 0
*   IT_ALV_GRAPHICS                   =
*   IT_HYPERLINK                      =
*   IT_ADD_FIELDCAT                   =
*   IT_EXCEPT_QINFO                   =
*   IR_SALV_FULLSCREEN_ADAPTER        =
* IMPORTING
*   E_EXIT_CAUSED_BY_CALLER           =
*   ES_EXIT_CAUSED_BY_USER            =
  TABLES
    t_outtab                          = IT_EKKO
* EXCEPTIONS
*   PROGRAM_ERROR                     = 1
*   OTHERS                            = 2
          .
IF sy-subrc <> 0.
* MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
*         WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
ENDIF.